app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
↳ QTRS
↳ Overlay + Local Confluence
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
APP(app(mult, app(s, x)), y) → APP(app(add, app(app(mult, x), y)), y)
FACT → APP(rec, mult)
FACT → APP(s, 0)
APP(app(add, app(s, x)), y) → APP(s, app(app(add, x), y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
APP(app(mult, app(s, x)), y) → APP(mult, x)
APP(app(add, app(s, x)), y) → APP(add, x)
APP(app(mult, app(s, x)), y) → APP(add, app(app(mult, x), y))
FACT → APP(app(rec, mult), app(s, 0))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
APP(app(mult, app(s, x)), y) → APP(app(add, app(app(mult, x), y)), y)
FACT → APP(rec, mult)
FACT → APP(s, 0)
APP(app(add, app(s, x)), y) → APP(s, app(app(add, x), y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
APP(app(mult, app(s, x)), y) → APP(mult, x)
APP(app(add, app(s, x)), y) → APP(add, x)
APP(app(mult, app(s, x)), y) → APP(add, app(app(mult, x), y))
FACT → APP(app(rec, mult), app(s, 0))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ ATransformationProof
↳ QDP
↳ QDP
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ ATransformationProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
add1(s(x), y) → add1(x, y)
add(0, x0)
add(s(x0), x1)
mult(0, x0)
mult(s(x0), x1)
rec(x0, x1, 0)
rec(x0, x1, s(x2))
add(0, x0)
add(s(x0), x1)
mult(0, x0)
mult(s(x0), x1)
rec(x0, x1, 0)
rec(x0, x1, s(x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ ATransformationProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
↳ QDP
add1(s(x), y) → add1(x, y)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ ATransformationProof
↳ QDP
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ ATransformationProof
↳ QDP
↳ QReductionProof
↳ QDP
mult1(s(x), y) → mult1(x, y)
add(0, x0)
add(s(x0), x1)
mult(0, x0)
mult(s(x0), x1)
rec(x0, x1, 0)
rec(x0, x1, s(x2))
add(0, x0)
add(s(x0), x1)
mult(0, x0)
mult(s(x0), x1)
rec(x0, x1, 0)
rec(x0, x1, s(x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ ATransformationProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
mult1(s(x), y) → mult1(x, y)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ UsableRulesProof
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ UsableRulesProof
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Narrowing
↳ UsableRulesProof
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
APP(app(app(rec, x0), x1), app(s, 0)) → APP(app(x0, app(s, 0)), x1)
APP(app(app(rec, x0), x1), app(s, app(s, x2))) → APP(app(x0, app(s, app(s, x2))), app(app(x0, app(s, x2)), app(app(app(rec, x0), x1), x2)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Narrowing
↳ QDP
↳ ForwardInstantiation
↳ UsableRulesProof
APP(app(app(rec, x0), x1), app(s, 0)) → APP(app(x0, app(s, 0)), x1)
APP(app(app(rec, x0), x1), app(s, app(s, x2))) → APP(app(x0, app(s, app(s, x2))), app(app(x0, app(s, x2)), app(app(app(rec, x0), x1), x2)))
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, x2)) → APP(app(app(rec, y_0), y_1), app(s, x2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0)) → APP(app(app(rec, y_0), y_1), app(s, 0))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_2))) → APP(app(app(rec, y_0), y_1), app(s, app(s, y_2)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Narrowing
↳ QDP
↳ ForwardInstantiation
↳ QDP
↳ ForwardInstantiation
↳ UsableRulesProof
APP(app(app(rec, x0), x1), app(s, 0)) → APP(app(x0, app(s, 0)), x1)
APP(app(app(rec, x0), x1), app(s, app(s, x2))) → APP(app(x0, app(s, app(s, x2))), app(app(x0, app(s, x2)), app(app(app(rec, x0), x1), x2)))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, x2)) → APP(app(app(rec, y_0), y_1), app(s, x2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0)) → APP(app(app(rec, y_0), y_1), app(s, 0))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_2))) → APP(app(app(rec, y_0), y_1), app(s, app(s, y_2)))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
APP(app(app(rec, x0), x1), app(s, app(s, app(s, y_2)))) → APP(app(app(rec, x0), x1), app(s, app(s, y_2)))
APP(app(app(rec, x0), x1), app(s, app(s, y_2))) → APP(app(app(rec, x0), x1), app(s, y_2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, 0))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0))
APP(app(app(rec, x0), x1), app(s, app(s, 0))) → APP(app(app(rec, x0), x1), app(s, 0))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_3))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, y_3))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, app(s, y_3)))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_3)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Narrowing
↳ QDP
↳ ForwardInstantiation
↳ QDP
↳ ForwardInstantiation
↳ QDP
↳ MNOCProof
↳ UsableRulesProof
APP(app(app(rec, x0), x1), app(s, app(s, app(s, y_2)))) → APP(app(app(rec, x0), x1), app(s, app(s, y_2)))
APP(app(app(rec, x0), x1), app(s, 0)) → APP(app(x0, app(s, 0)), x1)
APP(app(app(rec, x0), x1), app(s, app(s, x2))) → APP(app(x0, app(s, app(s, x2))), app(app(x0, app(s, x2)), app(app(app(rec, x0), x1), x2)))
APP(app(app(rec, x0), x1), app(s, app(s, y_2))) → APP(app(app(rec, x0), x1), app(s, y_2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, x2)) → APP(app(app(rec, y_0), y_1), app(s, x2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0)) → APP(app(app(rec, y_0), y_1), app(s, 0))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, 0))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0))
APP(app(app(rec, x0), x1), app(s, app(s, 0))) → APP(app(app(rec, x0), x1), app(s, 0))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_2))) → APP(app(app(rec, y_0), y_1), app(s, app(s, y_2)))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_3))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, y_3))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, app(s, y_3)))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_3)))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Narrowing
↳ QDP
↳ ForwardInstantiation
↳ QDP
↳ ForwardInstantiation
↳ QDP
↳ MNOCProof
↳ QDP
↳ UsableRulesProof
APP(app(app(rec, x0), x1), app(s, 0)) → APP(app(x0, app(s, 0)), x1)
APP(app(app(rec, x0), x1), app(s, app(s, app(s, y_2)))) → APP(app(app(rec, x0), x1), app(s, app(s, y_2)))
APP(app(app(rec, x0), x1), app(s, app(s, x2))) → APP(app(x0, app(s, app(s, x2))), app(app(x0, app(s, x2)), app(app(app(rec, x0), x1), x2)))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, x2)) → APP(app(app(rec, y_0), y_1), app(s, x2))
APP(app(app(rec, x0), x1), app(s, app(s, y_2))) → APP(app(app(rec, x0), x1), app(s, y_2))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0)) → APP(app(app(rec, y_0), y_1), app(s, 0))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, 0))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, 0))
APP(app(app(rec, x0), x1), app(s, app(s, 0))) → APP(app(app(rec, x0), x1), app(s, 0))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_2))) → APP(app(app(rec, y_0), y_1), app(s, app(s, y_2)))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_3))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, y_3))
APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, app(s, y_3)))) → APP(app(app(rec, app(app(rec, y_0), y_1)), x1), app(s, app(s, y_3)))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ MNOCProof
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ MNOCProof
↳ QDP
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
app(app(app(rec, f), x), 0) → x